11602. Два
хоровода
Однажды n человек (n четное)
встретились на площади и устроили два хоровода. Найдите количество способов,
которыми n человек могут водить два хоровода, если каждый хоровод должен
состоять ровно из n / 2 человек. Каждый человек должен принадлежать
ровно к одному из этих двух хороводов.
Хоровод – танцевальный круг,
состоящий из 1 и более человек. Два хоровода называются неразличимыми
(равными), если один можно преобразовать в другой выбором первого участника.
Например, хороводы [1, 3, 4, 2], [4, 2, 1, 3] и [2, 1, 3, 4] неразличимы.
Вход. Одно четное целое число n (2 ≤ n ≤ 20).
Выход. Выведите количество способов
составить два хоровода. Гарантируется, что ответ помещается в 64-битный
целочисленный тип данных.
Пример входа |
Пример выхода |
4 |
3 |
комбинаторика
Сначала следует
выбрать n / 2 людей для первого хоровода. Это можно сделать способами. Подсчитаем количество способов,
которыми можно поставить людей внутри одного хоровода. Зафиксируем того кто
будет первым, после чего остальных n / 2 – 1 людей можно расставить
произвольным образом, а именно (n / 2 – 1)! способами. Количество
способов составить два хоровода равно
* (n / 2 – 1)! * (n / 2 – 1)! /
2
Деление на 2 необходимо чтобы не
различать пары хороводов (x, y) и (y, x). Например, при n = 4 разделения на хороводы ([1, 2],
[3, 4]) и ([3, 4], [1, 2]) будем считать одинаковыми.
Упростим
указанную формулу и получим ответ:
* (n / 2 – 1)! * (n / 2 – 1)! /
2 =
= =
Пример
Например, при n = 4 количество способов равно 3:
·
первый раунд танца – [1, 2], второй – [3, 4];
·
первый раунд танца – [2, 4], второй – [3, 1];
·
первый раунд танца – [4, 1], второй – [3, 2].
По формуле для n = 4 ответ
равен
= = 3
Построим все различимые хороводы
для n = 4. На первом месте поставим участника 1. На остальных трех
местах можно поставить любую перестановку из трех остальных участников.
Вращая по кругу любую из
приведенных расстановок, можно получить неразличимые хороводы. Например,
неразличимыми будут (рассмотрим циклические сдвиги последней перестановки):
[1, 4, 3, 2], [2, 1, 4, 3], [3, 2,
1, 4], [4, 3, 2, 1]
Имеется 4! = 24 хороводов из 4
участников. Однако различимых хороводов для n
= 4 имеется 3! = 6.
Реализация алгоритма
Функция fact вычисляет факториал числа n.
long long fact(int n)
{
long long res = 1;
for (int i = 2; i <= n; i++)
res
*= i;
return res;
}
Основная часть программы. Читаем входное число n.
scanf("%d", &n);
Вычисляем и выводим ответ.
res = 2 * fact(n - 1) /
n;
printf("%lld\n", res);
Python реализация
Функция fact вычисляет факториал числа n.
def fact(n):
res = 1
for i in range(2, n + 1):
res *= i
return res
Основная часть программы. Читаем входное число n.
n = int(input())
Вычисляем и выводим ответ.
res = 2 * fact(n - 1) // n
print(res)